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(57) Abstract: A data processing system (102) includes an associative memory device (104) containing n-cells, each of the n-cells 
includes a processing circuit (130). A controller (100) is utilized for issuing one of a plurality of instructions to the associative 
memory device (104), while a clock device (106) is utilized for outputting a synchronizing clock signal comprised of a predetermined 
number of clock cycles per second. The clock device (106) outputs the synchronizing clock signal to the associative memory device 
(104) and the controller which globally communicates one of the plurality of instructions to all of the n-cells simultaneously, within 
one of the clock cycles. 
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CELLULAR ENGINE FOR A DAT A PROCESSING SYSTEM 

CROSS REFERENCE TO RELATED APPLICATIONS 

This application claims priority to U.S. Provisional Application Serial No. 
60/431,154 entitled "ENHANCED VERSION OF CONNEX MEMORY", and filed 
on December 5, 2002, hereby incorporated by reference in its entirety. The 
subject matter of this application relates to pending U.S. Patent Application Serial 
No. 09/928,151 entitled "A MEMORY ENGINE FOR THE INSPECTION AND 
MANIPULATION OF DATA", filed on August 10, 2001 and U.S. Patent 
AppHcation entitled "DATA PROCESSING SYSTEM FOR A CARTESIAN 
CONTROLLER", filed December 4, 2003, both of which are herein incorporated 
by reference in their entirety. 

nELD OF THE INVENTION 

The invention relates generally to an engine for a data processing system, 
and more particularly, to a cellular engine for a data processing system that 
implements an active associative memory device, or associative engine, to 
increases data processing speeds and efficiency. 

BACKGROUND OF THE INVENTION 

Automated or semi-automated data processing systems are integral 
components in a wide variety of applications. Typically, data management 
systems are embedded within a larger computerized apparatus or system and 
serve to assist or facilitate those applications running in the larger computerized 
system, such as by performing necessary arithmetic operands, data conversion 
or the like. 

As is known, basic data processing systems may be categorized as single 
instruction, single data stream (SISD) devices and typically utilize, in their 
simplest expression, a processor, an interface and a memory device. The 
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processor performs directed tasks in response to instructions inputted either by 
a user, or by another component of an overall system. In performing its 
designated tasks, the processor relies upon the interface to communicate 
commands, such as data requests, to the memory device, as well as to receive 
5 thereby specified data stored within the memory device. 

Known data processing systems most often utilize conventionally 
addressed memory devices. That is, known data systems utilize memory 
devices which include defined locales therein, each locale having its own 

1 0 particularized address. In this maimer, should the processor desire to add the 

value stored at address A with the value stored at address B, the memory device 
will proceed to the specific, addressed locations, or cells, within the memory 
device, and communicate these values, via the interface, to the processor where 
the appropriate summation can occur. In such systems, the nature and 

1 5 capability of the integral components, that is, the nature and capabilities of the 
processor and the memory devices, are well defined and distinct from one 
another. Figure 1 depicts such a known data processing system wherein 
processor 2 operates in response to tasks inputted via input line 4. An interface 
6 is thereafter utilized to communicate instructions, such as data requests, to the 

20 memory device 8, as well as to receive thereby specified data stored within the 
memory device 8. 

It is also known that data processing systems may include more than one 
processor and memory device, and further, that these multiple components 

25 may be part of a system that executes multiple streams of instructions. These 
multiple instruction streams, multiple data streams (MIMD) devices can be 
viewed as large collections of tightly coupled SISD devices where each processor 
in the system, although operating in overall concert with the other integrated 
processors, is responsible for a specific portion of a greater task. That is, the 

3 0 effectiveness of MIMD devices is typically limited to those specified arenas 

where the problem to be solved lends itself to being parsable into a plurality of 
similar and relatively independent sub-problems. The nature and capabilities of 
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those integral components of MIMD devices are also well defined and distinct 
from one another. 

Another known data processing system involves single instruction, 
5 multiple data streams (SIMD) devices. These SIMD devices utilize an arbitrary 
number of processors which all execute, in sync with one another, the same 
program, but with each processor applying the operator specified by the current 
instruction to different operands and thereby producing its own result. The 
processors in a SIMD device access integrated memory devices to get operands 
1 0 and to store results. Once again, the nature and capabilities of those integral 

components of a SIMD device are well defined and distinct from one another in 
that computations are executed by the processors that must have some type of 
access to a memory device to do their job. 

1 5 While known data processing systems are therefore capable of 

processing large amoimts of data, the defined and unchanging nature of the 
processors and memory devices limits the speed and efficiency at which various 
operations may be completed. 

20 Various architectures have also been constructed which utilize another 

class of memory devices which are not conventionally addressed. These 
memory devices are typically described as being 'associative' memory devices 
and, as indicated, do not catalog their respective bits of data by their location 
within the memory device. Rather, associative memory devices 'address' their 

2 5 data bits by the nature, or intrinsic quality, of the information stored therein. 

That is, data within associative memory devices are not identified by the name 
of their locations, but firom the properties of the data stored in each particular 
cell of the memory device. 

30 A key field of fixed size is attached to all data stored in most associative 

memory devices. A search key may then be utilized to select a specific data 
field, or plurality of data fields whose attached key fileld(s) match the search 
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key, from within the associative memory device, irrespective of their named 
location, for subsequent processing in accordance with directed instructions. 

While the implementation of associative memory devices is therefore 
5 known, these devices have always been utilized as specialized blocks, or 
components, within known data processing systems employing standard 
processors, interfaces and conventionally addressed memory devices. That is, 
although known associative memory devices do not employ conventional 
addressing protocols, they are incapable of processing the information 
1 0 themselves, relying instead upon known processors and external memory 

devices in a maimer consistent with known SISD, SIMD and MIMD architectures. 

With the forgoing problems and concerns in mind, the present invention 
therefore seeks to provide an engine for a data processing system that 
1 5 overcomes the above-described drawbacks by utilizing an active associative 
memory device using variable-size keys whose cells, by selectively acting as 
both a processor and a memory device, never have to access a separate 
memory block to do their jobs, thus substantially reducing processing, 
computational and conimunication times. 

20 

SUMMARY OF THE INVENTION 

It is an object of the present invention to provide an efficient data 
processing system. 

25 

It is another important aspect of the present invention to provide a 
cellular engine for a data processing system that implements an active 
associative memory, or associative engine device, in a manner which increases 
data processing speeds and efficiency. 

30 

It is another important aspect of the present invention to provide a 
cellular engine for a data processing system that implements an active 
associative memory, or associative engine device whose cells, by selectively 
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acting as both a processor and a memory device, never have to access a separate 
memory block to do their jobs. 

It is another important aspect of the present invention to provide a 
5 cellular engine for a data processing system that implements an active 

associative memory device, or associative engine, whose individual cells can 
selectively process a given instruction based upon their respective state as set by 
a globally propagated instruction or query. 

10 It is another important aspect of the present invention to provide a 

cellular engine for a data processing system that implements an active 
associative memory device, or associative engine, whose individual cells can 
selectively process, in parallel, a given instruction based upon their respective 
state, all within a single clock cycle. 

15 

It is another important aspect of the present invention to provide a 
cellular engine for a data processing system that implements an active memory 
device, or cellular engine, that allows the use of variable-length key fields. 

20 It is another important aspect of the present invention to provide a 

cellular engine for a data processing system that implements an active memory 
device, or cellular engine, whose structure is homogeneous, thus allowing the 
very same piece of information stored in memory to be (part of) either the key 
field or data field at different times during the execution of a program. 

25 

It is another object of the present invention to provide a cellular engine 
for an efficient data processing system that enables the dynamic limitation of the 
search space within an active associative memory device. 



30 



It is another object of the present invention to provide a cellular engine 
for an efficient data processing system that provides for the selective 
accessibility of either end of the cell array. 
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It is another object of the present invention to provide an engine for an 
efficient data processing system which is capable of regulating data transmission 
between two or more cells within an associative memory device. 

5 According to one embodiment of the present invention, a data processing 

system includes an associative memory device containing n-ceDs, each of the n- 
cells includes a processing circuit- A controller is utilized for issuing one of a 
plurality of instructions to the aissodative memory device, while a clock device is 
utilized for outputting a synchronizing clock signal comprised of a 
1 0 predetermined number of clock cycles per second. The clock device outputs the 
synchronizing clock signal to the associative memory device and the controller 
globally communicates one of the plurality of instructions to all of the n-cells 
simultaneously, within one of the clock cycles. 

1 5 These and other objectives of the present invention, and their preferred 

embodiments, shall become clear by consideration of the specification, claims 
and drawings taken as a whole. 



20 



BRIEF DESCRIPTION OF THE DRAWINGS 

Figure 1 is a block diagram illustrating a known SISD data processing 
architecture. 



Figure 2 is a block diagram showing the general configuration of a data 
2 5 processing system, including a memory engine and a synchronizing dock 
element, according to one embodiment of the present invention. 

Figure 3 is a block diagram showing a more detailed view of the memory 
engine shown in Figure 2. 



30 



Figure 4 is a block diagram showing the structure of a cell, or processing 
element, according to one embodiment of the present invention. 
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Figure 5 is a block diagram showing the structure of the transcoder. 

DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENT 

5 Figure 2 depicts the architectural relationship between a controller 100, 

hereinafter referred to as the Cartesian Controller (CC), and a cellular engine 
102, hereinafter referred to as the Connex Engine (CE). A synchronizing clock 
circuit 106 is utilized to coordinate the operation of the CC 100 and the CE 102 
such that one of a plurality of instructions may be issued by the CC 100 and 
1 0 transferred to the CE 102 for parallel execution and processing. 

The clock circuit 106 is capable of outputting a predetermined number of 
clock cycles per second, and the CC 100 is capable of performing an internal 
operation such that the CC 100 may perform one of a plurality of internal 
1 5 operations while also issuing in parallel one of a plurality of instructions to the 
CE 102 within a single clock cycle. 

As depicted in Figure 3, the CE 102 is made up of an array of active cells, 
or processing elements, embodied as the Connex Memory (CM) 104 and a RAM 

20 (random access memory) containing a plurality of vectors 108, each vector 
having the same storage capacity as the CM 104 and thus being capable of 
selectively storing the entire contents of the CM 104. That is, the CE 102 includes 
the CM 104 having n- cells and the associated vector memory 108, which is 
under the control of the sequential CC 100. In one embodiment of the present 

25 invention, the purpose of the memory vectors 108, is to allow for search, insert 
and delete operations to be performed on character strings longer than may be 
accommodated within the CM 104, and to offer a lower cost of implementation 
and reduced power dissipation, as will be discussed in more detail later. 

30 It will be readily appreciated that the present invention contemplates that 

the CE 102 may have any number of circuit-specific configurations without 
departing from the broader aspects of the present invention provided that the 
CC 100 is capable of issuing commands to, and receiving data from, the CE 102. 
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Referencing Figure 3, each n-bit cell in the CM 104 contains the following 
registers: 

• 'mark' - a one-bit marker register; 
5 • V - the main register, which plays a role similar to that of an 

accumulator in a more conventional design, while also being associated with a 
number of general registers equal to the number of memory vectors. 

Notations: Let x be a bit field of length m and y be a bit field of length n: {x, y] 
1 0 denotes a bit field of length m + n formed by appending y to x. The notation can 
be generalized to any number of bit fields, e.g. for three arguments: {a, b, c} = {a, 
{b,c}) = {{a,b},c}. 

Let r be an (n + l)-bit register and n>k>0: r[k] denotes the (fc + 1) - th bit 
15 in r, coimting from the right end {k = 0) to the left end {k = n). 

Let r be an (n + 1) bit register and n>m>k>0: r[m:k] denotes a bit field 
of length m-k+1, {r[m], rtm-l], . . . , r[k]). 

20 Therefore, the contents of an m- bit cell within the CM 104 are the 

contents of its w register appended to the contents of its mark register; 
cell [m-l:0] = {mark, value) 
value [m-2:0] = {ext, symbol} 
symbol [m-3:0] 

25 where ext stands for the extension bit, used to create an alphabet of special 
values (for ext = 1), 

An important aspect of the present invention resides in the ability of each 
m-bit cell within the CM 104 to actively process data in addition to storing data. 
30 The processing of data may occur either Mdthin each m-bit cell, or by affecting 
the cell immediately to the left or right of a predetermined cell. It should be 
noted that by enhancing the functionality of each m-bit cell within the CM 104 in 
this manner, the present invention exhibits a system-level behavior that is more 
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complex and, as such, exceeds the performance of other data processing 
systems. 

It is another important aspect of the present invention that the ability to 
actively process data at the cell level within the CM 104 is accomplished, in part, 
by the ability of each cell to be 'marked', which is part of the condition, or 
predicate, designating it as a cell which will subsequently perform a task, or 
execute an operand, on itself, or an adjacent cell within the CM 104. 

Returning to Figure 3, for the purposes of the present invention, a cell is 
considered 'marked' if the one-bit, internal ceD register mark = 1 and is 
considered 'not marked' if mark = 0. Moreover, the CM 104 has a 'left limit' and 
a 'right limit' that can be dynamically adjusted by issuing specialized 
instructions. In addition, the 'search space' of the CM 104 is that segment of the 
CM 104 which is delimited by the left limit and the right limit. It will be readily 
appreciated that the internal cell register mark may be greater than one bit in 
length without departing from the broader aspects of the present invention. 

As mentioned previously, the execution of code supplied to the CE 102 is 
driven by the CC 100. The CE 102/CC 100 interface makes use of four special 
registers, as shown in Figure 3: 

• *INR* 112 - data input register - all CE 102 instructions get their 
(immediate) data argument (if any) from INK (supplied by CC 100); 

• 'OUTR* 114 - data output - contains the 'no mark' bit and a value. If 
at least one of the cells is marked, OUTR contains 0 followed by the value 
contained in the first marked cell; otherwise OUTR contains 1 followed by an 
implementation-dependent special value, such as 11... 1; 

• 'OPR' 116 - instruction register, contains the operation code for the 
current CE 102 instruction (the source is a dedicated field in the CC 100 
instruction); 

• 'VAR' 118 - address register for the vector memory. The VAR 118 
register is updated by special CC 100 instructions and is used as an argument to 
instructions that explicitly manipulate vectors; The VAR 118 register is also used 
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in the execution of all operations involving the general registers assodated with 
cells. 

As further represented in Figure 3, input/output lines 120 may be 
5 selectively utilized to access both ends of the CM 104. As utilized herein, the 
input/output lines 120 have the following meaning: 

• 'leftjn' 122 = [w, mark, eq, first), by default all are 0 (eq = 1 means 
that the two operands in the cell are equal; first = 1 means the cell is the first 
marked cell); 

10 • left_out' 124 = {w, mark, eq, first}, come from the first cell; 

• 'right_in' 126 = {w, mark, eq, first}, by default all are 0; 

• nght_out' 128 = {w, mark, eq, first}, come from the last cell. 

15 

Figure 4 illustrates one embodiment of an internal structure of the m-bit 
cells within the CM 104. As shown in Figure 4, the internal structure of each cell 
includes the following circuits: 

• ALU: arithmetic and logic unit 130 that performs addition, 
20 subtraction, comparisons, and bitwise logic functions 

• leftMux: multiplexer 131 which selects the left operand for ALU 

from: 

♦ w: the value stored in the accumulator register 134 
« in: the value received from the input register 112 
25 « memOut: the value read from the vector memory addressed 

by the vector address register, VAR 118 

• aluMux: multiplexer 133, which selects the value to be loaded into 
the accumulator register (w 134) from: 

i> w: the value stored in the accumulator register 134 
30 o f romLef t: the value stored in the accumulator register of the 

left cell 

o fromRight: the value stored in the accumulator of the right 

ceU 



wo 2004/053718 



PCT/US2003/038893 



1 1 

« the output of ALU 130 

• w: the accumulator register 134 

• mark: the marker register 

• tristate output buffers 

5 • DECODE: a combinational circuit 137 which decodes the 

instructions according to the local context generated by: 
o localFIags: generated by ALU 
« leftFlags: the flags received from the left cell 
« rightFlags: the flags received from the right cell 
10 « class_i: classification code received from the 

TRANSCODER generating: 

■ command codes for leftMux, rightMux, ALU, 
aluMux, mark, tristate buffers 

■ flags from neighboring cells 

1 5 ■ state J bit of the ceU for the TRANSCODER 

The Transcoder 

Figure 5 illustrates the organization of the TRANSCODER, a circuit 
20 integrated with the CE 102 and acting as part of a control interconnection 

network. That is, the TRANSCODER is utilized, in part, to classify each cell 
according to: 

• its state bit (state_i), (i.e. the local state) 

• the state bits of all cells, (i.e. the global state) 
25 • the current instruction to be performed, 

into the following categories: 

• marked cell 

• first marked cell 

• last marked cell 

30 • cell within limits (the limits are stored in a memory area of the 

TRANSCODER) 

• active cell. 
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It will be readily appreciated that other cell categories could be added to 
the above without departing from the broader aspects of the present invention. 

The TRANSCODER receives from each cell a state bit (state_0, state J,..., 
5 state_(n-l)) and sends back to each cell a 3-bit code specifying the dass(es) to 
which it belongs (class^O, class J, class_(n-l)). 

The building blocks of the transcoder are: 

• OR Prefixes: a circuit 140 calculating mainly the relative positions 
of cells according to the classification to be performed 

• Limit memory: two latches 141 used to store information about the 
limits 

• MUXs: multiplexers 142 which, based on the current instruction, 
select the class of each cell 

The TRANSCODER can be implemented in two different ways in order 
to optimize its size and speed: 

• a linear version for small values of n 

• a bi-dimensional version (for large values of n), containing a LINE 
TRANSCODER and a COLUMN TRANSCODER, each having a size of 
the order 0(n'^^). 

Another important aspect of the present invention, therefore, is the 
ability of the CC 100 to issue instructions to the CE 102 and cause such 
25 instructions to be broadcast, in parallel and in a single clock cycle, to all cells 
within the CM 104. Those cells meeting the criteria set out in the instructions 
from the CC 100 may, for example, independently and selectively mark 
themselves, simultaneously in the same clock cycle, whereby subsequent 
instructions or operations, in the following clock cycle, may be effectuated 
3 0 according to the resulting classification, again in parallel and in a single clock 
cycle. 



10 



15 



20 
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It is therefore another important aspect of the present invention that the 
TRANSCODER not only classifies each cell in accordance with its local state, for 
example, its marked or non-marked state, but also in accordance to its global 
state and the current instruction. That is, while one aspect of a cell's classification 
5 by the TRANSCODER may be that a particular cell's local state is 'marked', it is 
also important for such a cell to 'know' its 'global state' with respect to all other 
cells, such as whether the 'marked' cell is the 'first marked' cell or the 'last 
marked' cell. 

10 By way of an example, suppose certain cells within the CM 104 have been 

marked, via some property of these cells as indicated by an instruction from the 
CC 100 in the previous dock cycle, as follows: (marked cells being represented 
by bolded numbers in the string): 

15 CM: 2 5 2 7 6 4 10... 

Suppose next that the uistruction "addr 5" is broadcast to all cells within 
the CM 104, again in parallel and in a single clock cycle, where vector 5 in the 
vector memory 108 is as follows: 

20 

Line 5: 3 4 7 8 2 5 12 ... 

All marked cells within the CM 104 will then add the contents of their 
data field to the contents of the corresponding element in vector 5, with the 
25 result of this operation being stored in the respective cells of the CM 104, as 
follows: 

CM: 5 9 2 7 6 9 10 ... 

30 As indicated by the example above, the marked /non-marked state of 

each cell within the CM 104 is not affected by the particular instruction issued by 
the CC 100 (in this example; although as noted, certain instructions will affect the 
marked state of each cell within the CM 104). Moreover, all addition operations 
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are executed simultaneously (that is, in parallel with one another) and internal to 
each marked cell within a single clock cycle. 

As further indicated by the example above, the data processing system of 
5 the present invention can implement, at the system level, operations defined on 
vectors of values; in this example the vector values are the CM 104 data and 
vector 5 of the vector memory 108. In this regard, the data processing system 
of the present invention includes a CE having a CM 104 with a linear array of 
active cells (i.e., processing elements) where each cell within the CM 104 has one 
10 or more marker bits and one accumulator (134); at same time, at the level of 
each cell, the corresponding elements of all vectors can be seen as a set of 
associated registers, (the number of associated registers is therefore equal to the 
number of vectors 108). 

1 5 Moreover, it is another important aspect of the present invention that by 

concatenating the accumulators and individual associated registers of each cell 
within the CM 104 respectively, the data processing system of the present 
invention provides for operations on vectors of values, thereby enabling matrix 
computations and the like. 

20 

As contrasted to SIMD and MIMD systems, discussed in the Background 
of the present invention, the data processing system of the present invention 
does not rely upon an unchanging and strict delineation between the operations 
of a processor and a linked memory device. 

25 

In the data processing system of the present invention, information may 
be stored for retrieval in the CM 104, but conventional "memory address' is not 
a concept; although each cell within the CM 104 may itself selectively process 
information in response to globally issued commands, it is not a processor per 
3 0 se, although each cell within the CM 104 does contain a processing circuit, as 

discussed previously; and the performance of the data processing system of the 
present invention is strictly a linear function of its size and applicable across a 
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wide range of programs /applications in a manner that is not exhibited by other 
known programmable machines. 

It will be readily appreciated that the data processing system of the 
5 present invention is not limited in the nature and configuration of the processing 
circuit contained within each of the «- cells in the CM 104. 

In accordance with the present invention, the CE 102 has a rich set of 
instructions, grouped in the following classes: 
10 • global management - setting and resetting the CM 104 limits; 

exchanging data between the CM 104 and RAM vectors 108; 

• search/access - associative access to one or more of the cells of the 
CM 104; 

• marker manipulation; 
15 • data store and transfer; 

• arithmetic and logic; 

• conditional; and 

• index. 

20 Note that all instructions for the CE 102 are executed in a single machine 

cycle. 

The CE 102 does not itself have access to a program memory to fetch its 
instructions - every cycle its cells expect to get an operation code in a special 

25 register, but it takes a different entity, in the present case, the CC 100, to do it 
for them; the code is sequential and there needs to be a single point of access to 
fetch it. The main job of the CC 100 is therefore to drive the execution of the 
programs of the CE 102, i.e., fetch instructions to be executed by individual cells 
and place them in an internal register; at the same time, it serves as a gateway to 

30 CE 102 and thereby takes care of all input/output interactions. The CC 100 also 
executes simple sequential operations without which it would be impossible to 
write meaningful code for such a machine: one class of such operations are the 
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so-called "control primitives", i.e., those instructions that are used to code 
decision-making sequences (e.g. if, while, repeat, etc). 

Fseudocode 

5 

In the following, pseudocode that uses a notation inspired from the C 
programming language is utilized to specify informally the semantics of most 
instructions of the CE 102. It will be readily appreciated that this kind of 
description is not intended to limit the expression of the actual implementation 
10 of instructions, and that other expressions are also contemplated by the present 
invention. 

A special pseudo-statement, /ora//, describes actions executed by sets of 
cells in parallel; its syntax may be expressed as: 
15 • <forall statement> : := forall [(<forall condition>)] <statement>; 

• <forall condition> : := marked 

I in searchSpace; 

Consider the following three variants oi forall: 

1. forall 

<action>; 

2. forall (in searchSpace) 
<action>; 

3. forall (marked) 
<action>; 

Variant 1 may be utilized to specify an action executed by all the cells in 
the CM 104. Variant 2 may be utilized for an action involving all the cells in the 
search space (see above), while variant 3 applies to cases when all marked cells 
3 0 execute the specified action. 

At the level of each cell, the complete data set needed to execute all the 
instructions, together with their names used in pseudo-code, are: 



20 



25 
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• the cell's registers (including associated registers), i.e. 
mark, rO, rl, . . , , rN; and 

• the content of the cell's right and left neighbors, i.e. right_w, 
right_mark, and left_w, left_mark respectively. 

5 

At the same time, predicates first_mark and last_mark can be evaluated 
at the cell level; the former is true for the leftmost marked cell in CM, while the 
latter is true in the case of the rightmost marked cell. 

1 0 Global Management Instructions 

Idl <value>: load line immediate; the contents of all CM cells (markers 
and w registers) are restored from the memory vector selected by the value 
generated to the input of VAR: 



15 



CM = RAM[VAR]; 



stl <value>: store line immediate; the contents of all CM cells (markers 
and w registers) are saved to the memory vector selected by the value 
2 0 generated to the input of VAR 

RAM[VAR]=CM; 

Him: left limit; sets the left limit of the search space to the first marked 

2 5 cell. No markers are affected. Note that the left linut is the leftmost cell affected 

by search/access instructions. 

rlim: right limit; sets the right limit of the search space to the first marked 
cell. No markers are affected. Note that the right limit is the rightmost cell 

3 0 affected by basic search/access instructions. 



droplim: remove limits; the left limit is set to the leftmost CM cell, while 
the right linut is set to the rightmost CM cell. No markers are affected. 
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Search/Access Instructions 

Note: All the instructions described in this section act only within the 
limits of the search space; arguments are m-1 bit values available in the input 
register (INR). 

find <value>: identifies all the cells holding values equal to the argument. 
For every cell where a match is found, the marker bit of its right neighbour is 
set to one; all the other marker bits are set to 0: 

forall (in searchSpace) 

mark = (left.w == INR)? 1: 0; 

match <value>: compares values stored in all marked cells to the 
argument. If a match is found in a given cell, the marker bit of the following cell 
is set to 1; all the other marker bits are set to 0: 

forall (in searchSpace) 

mark = (left^mark && left^w == INR)? 1: 0; 

Ifind <value>: find and mark left; identifies all cells holding a value equal 
to the argument. For every cell where a match is found, the marker bit of its left 
neighbour is set to one; all the other marker bits are set to 0: 

forall (in searchSpace) 

mark = (right.w == INR)? 1: 0; 

Imatch <value>: match and mark left; compares values stored in all 
marked cells to the argument. If a match is found in a given cell, the marker bit 
of the preceding cell is set to 1; all the other marker bits are set to 0: 

forall (in searchSpace) 

mark = (right.mark && right_w == INR)? 1: 0; 
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markall: marks all cells in the search space: 

forall (in searchSpace) 
mark = 1; 

5 

addmark <value>: marks all the cells containing a value equal to the 
argument; no other markers are affected: 

forall (in searchSpace) { 
10 if(w==INR) 
mark = 1; 

) 

mark <value>: marks all the cells containing a value equal to the 
1 5 argument; all the other marker bits are set to 0. 

forall (in searchSpace) 

mark = (w == INR)? 1: 0; 

20 dr <value>: clears the marker bit of all cells containing a value equal to 

the argument. 

forall (in searchSpace) { 
if (w == INR) 
2 5 mark - 0; 

I 

Marker Manipulation Instructions 



30 



clrf : clear first; clears the first (i.e. leftmost) marker. 
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forall I 

if (first^mark) 
mark = 0; 

) 

5 

trace: duplicates markers leftward, 
forall { 

if (right_mark) 
10 mark = l; 

if (mark) 

mark = 1; 

I 

1 5 keepl: keep last; clears all markers except the last (i.e. rightmost) one. 

forall { 

if (!last_mark) 

mark = 0; 

20 } 

clrl: clear last; clears the last (i.e. rightmost) marker, 
forall { 

25 if (last^mark) 

mark = 0; 

} 



30 



left: shifts all markers one cell to the left, 
forall 

mark = right_mark; 
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right: shifts all markers one cell to the right, 
forall 

mark = left_mark; 

cright: conditional shift right; all markers are shifted one cell to the right 
unless their right neighbour contains a value equal to the argument, in which 
case 11. ..1 is substituted for that value. 

forall { 

if (left_mark && w == INR) { 
mark = 0; 
w = 11...1; 

} 

if (left_mark && w != INR) 

mark = 1; 
if (mark) 

mark = 0; 

I 

cleft: conditional shift left; all markers are shifted one cell to the left 
unless their left neighbour contains a given value, in which case 11...1 is 
substituted for the value. 

forall { 

if (right.mark && w == INR) { 
mark = 0; 
w = 11...1; 

} 

if (righ^mark && w != INR) 
mark = 1; 
if (mark) 
mark = 0; 

} 
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Data store and transfer instructions 
nop: no operation: 
5 reset <i;^i/Me>: stores a value in all cells. No markers are affected, 

forall 

w = INR; 

1 0 get: the value stored in the first marked cell is sent to the CM output and 

its marker moves one position to the right. No other markers are affected, 

forall { 

if (first_mark) { 

OUTR = w; 
mark = 0; 

} 

if (left_mark is first_mark) 
mark = 1; 

} 

back: the value stored in the first marked cell is sent to the CM output 
and its marker moves one position to the left. No other markers are affected. 

25 forall! 

if (first_mark) { 

OUTR = w; 
mark = 0; 

} 

30 if (right_mark is first_mark) 

mark = 1; 

} 



15 



20 
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set <value>: stores a value in the first marked cell. Markers are not 
affected. 

forall (marked) { 

if (first_mark) 
w = INR; 

} 

setall <value>: stores a value in all marked cells. Markers are not affected. 

forall (marked) 
w = INR; 

ins <value>: inserts a value before the first marked cell. The contents of 
all cells to the right of the insertion point are shifted one position to the right. 
Note that the value initially held in the rightmost cell is lost in the process. 

forall { 

if (right of first_mark) 

w = left_w; 
if (first_mark) 

w = INR; 
mark = left_mark; 
) 

del: deletes the value stored in the first marked cell. The cell remains 
marked and the contents of all cells to the right of the deletion point are shifted 
one position to the left. 
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foraU { 

if (£irst_mark) 

w = right_w; 

if (right of first_mark) { 
w = right_w; 

mark = right_mark; 

) 



1 0 cpr: copy right; for all marked cells, copies the whole cell contents (w 

register and marker) to the right neighbour. 

forall { 

if (left„mark) 
15 w = left_w; 

mark = left_mark; 



cpl: copy left; for all marked cells, copies the whole cell contents (w 

2 0 register and marker) to the left neighbour. 

forall { 

if (right_mark) 

w = right_w; 

25 mark = right_mark; 

} 

ccpr <value>: conditional copy right; for all marked cells, copies the value 
held in register w to the right neighbour; markers are also copied, unless a value 

3 0 equal to the argument is stored in w. 
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forall { 

if (left^mark && left.w != INR) { 
w = left_w; 
mark = 1; 

5 ) 

else 

mark = 0; 

} 

1 0 cqpl <value>: conditional copy left; for all marked cells, copies the value 

held in register w to the left neighbour; markers are also copied, imless a value 
equal to the argument is stored in w. 

forall { 

1 5 if (right^mark && right_w != INR) { 

w = right_w; 
mark = 1; 

I 

else 

20 mark = 0; 

} 

Id <address>: load immediate; for all marked cells, load into w the value 
held in register <r>, part of the RAM vector selected by the value generated to 
25 the input of VAR . 

forall (marked) 
w = <r>; 



30 



st < address>: store immediate; for all marked cells, move the value held 
in w to register <r>, part of the RAM vector selected by the value generated to 
the input of VAR. 
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forall (marked) 
w = <r>; 

Arithmetic & Logic Instructions 

All arithmetic instructions are carried out on m-2 bit numbers 
represented in 2's complement: the operand <op> is one of the associated cell 
registers (part of the RAM vector selected by the value generated to the input of 
VAR), or a m-2 bit ntimber supplied by the controller: 

<op> ::= INR[m-3:0](immediate value) I r(RAM vector element) 

add <op>: add the operand to the w register of all marked cells. Markers 
are not affected. 

forall (marked) 

w += <op>; 

fadd <op>: full add, with the right extension being treated as a carry (see 

add). 

forall { 

if (mark) 

w += (<op> + right_w[m-2]); 
if (left^mark) 

w[m-2] = 0; 

) 

sub <op>: subtract the operand value from the value stored in the w 
register of all marked cells. No markers are affected. 

forall (marked) 

w -= <op>; 
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fsub <op>: full subtract, with the right extension being treated as a carry 
(see sub). 

forall { 

if (mark) 

w -= (<op> + right_w[m-2])); 
if (left.mark) 

w[m-2] = 0; 

} 

half [<op>]: for all marked cells, divide by 2 the register operand and 
store the result in w. No markers are affected. 



forall (marked) 
15 w = {<op>[m-2:m-3], <op>[m-3:l]; 

fhalf l<op>]: full half; for all marked cells, divide by 2 the register 
operand and store the result in w, to which 100...0 is added if the least significant 
bit of the left cell is 1. Markers are not affected. 

20 

forall (marked) 

w = {<op>[m-2], left_w[0], <op>[m-3:l]; 

It <op> : less (or equal); for all marked cells, check whether register w 
25 holds a value that is less than, or equal to, that held in <op>; if w < op, then the 
w extension bit is set to 1; the marker bit is set to 0 if op > w. 

forall (marked) | 

if (w < <op>) 
30 w[m-2]=:l; 

if (w > <op>) 

mark = 0; 

} 
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fit <op> : full It; for all marked cells where w < op or whose left 
neighbour has the w extension bit set to 1, set the extension bit to 1; the left 
extension bit is cleared and if w > op the marker is also cleared. This instruction 
is used in conjunction with test for comparisons on multiple consecutive cells. 

forall { 

if (mark && (w < <op> I I left_w[m-2J)) 

w[m-2] = 1; 
if (right_mark) 

w[m-2] = 0; 
if (mark && w > op && !left_w[m-2]) 

mark = 0; 

) 

gt <op> : greater (or equal); for all marked cells, check whether register w 
holds a value that is greater than, or equal to, that held in <op>; if w > op, then 
the w extension bit is set to 1; the marker bit is set to 0 if w < op. 

forall (marked) { 

if (w > <op>) 

w[m-2] = 1; 
if (w < <op>) 

mark = 0; 

} 

fgt <op> : for all marked cells where w > op or whose left neighbour has 
the w extension bit set to 1, set the extension bit to 1; the left extension bit is 
cleared and if w < op the marker is also cleared. This instruction is used in 
conjunction with test for comparisons on multiple consecutive cells 
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forall { 

if (mark && (w > <op> I I left_w[m-2])) 

w[m-2] = 1; 

if (right_mark) 
5 w[m-2] = 0; 

if (mark && w < op && !left_w[m-2]) 
mark = 0; 

I 

1 0 test: For all marked cells containing a value equal to INR the marker bit is 

set to 0 and if the extension bit of the cell to the left is 1, then register w is 
assigned 11...1 and the extension bit of the cell to the left is cleared 

forall { 

1 5 if (right^mark && right_w == DMR) 

w[m-2] = 0; 
if (mark && w == INR && left_w[m-2]) 

w = 11...1; 
else if (mark && w == INR) 
20 mark = 0; 

} 

and <op> : bitwise and; for all marked cells, do a bitwise and between 
register w and <op>. Markers are not affected. 

25 

forall (marked) 

w &= <op>; 

or <op> : bitwise or; for all marked cells, do a bitwise or between register 
30 w and <op>. Markers are not affected. 



forall (marked) 

w I = <op>; 
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xor <op> : bitwise xor; for all marked cells, do a bitwise xor between 
register w and <op>. Markers are not affected. 

forall (marked) 
5 w ^= <op>; 

Conditional Instructions 

The following two instructions use an operand register, <r> (part of the 
1 0 RAM vector selected by the value generated to the input of VAR) and a m-l-bit 
value from INR. 

<r> ::= w(for register w) I r(RAM vector element) i 

1 5 cond <value> [<r>] : for all marked cells, check whether there is at least 

one bit set to 1 after executing a bitwise 'and' operation between the two 
operands. 

forall (marked) 
20 mark = ((<r> & ESfR) != 0)? 1: 0; 

ncond <value> [<r>] : for all marked cells, check whether the result of 
executing a bitwise 'and' operation between the two operands is 0. 

25 forall (marked) 

mark = ((<r> & INR) == 0)? 1: 0; 

Index Instruction 

3 0 index: for all marked cells, register w is assigned the value of the cell's 

relative position with respect to the CM leftmost cell (which has index 0). 
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As can be seen from the foregoing descriptions and drawing figures, the 
present invention provides a novel way to process data in a manner which 
provides increased processing power with a substantial decrease in processing 
time, silicon area and power consumption. As discussed, the data processing 
5 system of the present invention provides for any given instruction and its 
operand(s) to be communicated, in parallel, to all CM cells, which execute the 
instruction within the same clock cycle. 

Yet another inherent advantage of the data processing system of the 
1 0 present invention involves the ability of each cell within the cellular engine to 
not only simultaneously execute instructions within a single clock cycle, but to 
also dynamically limit those cells which execute these globally broadcast 
instructions via the utilization of both local and global state information. In 
particular, by utilizing marker bits on an individual ceD level, the actual cells 
1 5 within the associative memory are capable of affecting those cells either to the 
left or right of marked cells in a manner which is heretofore unknown. 
Therefore, at the system level, the present invention provides for the selective 
activation, or alteration of the marked state, by associative mechanisms; that is, 
by the nature or property of the content of the individual cells within the CM 
20 104, rather than a particular designated location address therein. 

The present invention therefore combines processing and memory at a 
very intimate level, meaning that an individual cell of the CM 104 never has to 
access a separate memory block to do its job. Moreover, operands reside in 
25 their own local space at the cell level, therefore results are kept in place, saving 
communication and processing time, silicon area and power. 

It should be noted that some instruction operands are, in fact, broadcast 
by the CC 100 at the same time as the instruction is globally broadcast. 

30 

While the invention had been described with reference to the preferred 
embodiments, it vdll be understood by those skilled in the art that various 
obvious changes may be made, and equivalents may be substituted for 
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elements thereof, without departing from the essential scope of the present 
invention. Therefore, it is intended that the invention not be limited to the 
particular embodiments disclosed, but that the invention includes all 
embodiments falling within the scope of the appended claims. 

5 
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WHAT IS CLAIMED IS: 

1. A cellular engine for a data processing system, said engine comprising: 
a data device having n- cells, each of said n- cells being able to store m 

bits; 

a vector memory containing p- vectors, each of said p- vectors having a 
storage capacity of n x m-bits; 

a control interconnection network that classifies each of said n- cells in 
dependence upon a local state of each of said n- cells; 

an instruction register for accepting an instruction issued from a 
controller; 

a clock device for outputting a synchronizing clock signal comprised of a 
predetermined number of clock cycles per second, said clock device outputting 
said synchronizing clock signal to said data device and said vector memory; and 

wherein said engine globally commimicates said instruction to all of said 
n-cells simultaneously within one of said dock cycles, said instruction being 
executed in parallel by selected cells within said data device, all within one of said 
clock cycles, in accordance with said classification of each of said n- cells by said 
control interconnection network. 

2. The cellular engine for a data processing system according to claim 1, 
wherein: 

said instruction is executed in parallel by all of said n- cells within said data 
device. 

3. The cellular engine for a data processing system according to claim 1, 
further comprising: 

a data interconnection network that connects each cell to its right and left 
neighbors respectively. 
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4. The cellular engine for a data processing system according to claim 1, 
wherein: 

said control interconnection network classifies each of said n- cells in 
dependence upon both a local state of each of said n- cells and a global state of 
5 all of said n- cells. 

5. The cellular engine for a data processing system according to claim 4, 
wherein: 

each of said n- cells include a state field and a data field, said state field 
comprising a marker bit for encoding a local state of each of said n- cells; and 
5 wherein said maker bit is in one of a marked state and a non-marked 

state. 

6. The cellular engine for a data processing system according to claim 5, 
wherein: 

said state field is modified using associative mechanisms as implemented 
by said execution of said instruction belonging to a specific subset of instructions 

7. The cellular engine for a data processing system according to claim 6, 
wherein: 

said data field is modified by executing logic and arithmetic instructions in 
said n- cells in accordance with said classification of each of said n- cells by said 
5 control interconnection network. 

8. The cellular engine for a data processing system according to claim 3, 
wherein: 

both of said data interconnection network and said control 
interconnection network are expandable. 

9. The cellular engine for a data processing system according to claim 1, 
wherein: 

said data device is an associative memory device. 
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10. The cellular engine for a data processing system according to claim 9, 
wherein: 

each of said n- cells in said associative memory device include a 
processing circuit. 

11. An engine for a data processing system, said engine comprising: 
a memory device contairung n-cells; 

a controller for selectively issuing an instruction to said memory device; 
a cell classification device v^hich operates in association with a local state 
of each of said n-ceUs; 

a clock device for outputting a synchronizing clock signal comprised of a 
predetermined number of dock cycles per second, said dock device outputting 
said synchronizing clock signal to said memory device and said controller; and 

wherein said engine globally conmixmicates said instruction to all n-cells 
simultaneously, within one of said clock cydes; and 

wherein said instruction is executed by selected cells within said memory 
device in dependence upon said local state of said n- cells as directed by said cell 
classification device, said execution of said instruction occurring simultaneously 
in each of said selected cells within one of said clock cyd^. 

12. The engine for a data processing system according to claim 11, wherein: 
said instruction is executed by all of said n- cells within said memory 

device. 



13. The engine for a data processing system according to claim 11, wherein: 
said memory device is not conventionally addressed. 

14. The engine for a data processing system according to claim 1 1, wherein: 
said memory device is an associative memory device. 

15. The engine for a data processing system according to claim 11, wherein: 
each of said n- cells indudes a processing drcuit. 



wo 2004/053718 



PCT/US2003/038893 



36 

16. The engine for a data processing system according to claim 15, wherein: 
said processing circuit has an accumulator. 

17. The engine for a data processing system according to claim 11, wherein: 
each of said n-cells includes a field having a marker bit; and 

said local state reflects one of a marked state and a non-marked state of 
said marker bit. 

18. The engine for a data processing system according to claim 11, wherein: 
said cell classification device operates in association with a global state of 

said n-cells; and 

wherein said instruction is executed by selected cells within said memory 
5 device in dependence upon said local state and said global state of said n- cells as 
directed by said cell classification device, said execution of said instruction 
occurring simultaneously in each of said selected cells within one of said clock 
cycles. 

19. The engine for a data processing system according to claim 18, wherein: 
said global state utilized by said classification device is determined by said 

local states of all said n -cells. 

20. The engine for a data processing system according to claim 17, wherein: 
said instruction is executed only within those n-cells having said marker 

bit set to said marked state. 

21. The engine for a data processing system according to claim 11, wherein: 
each of said ^z-cells includes a field having a plurality of marker bits. 
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22. A data processing system, said data processing system comprising: 
an associative memory device containing n-cells, each of said n-cells 

including a processing circuit and m- bits of memory capacity; 

a controller for issuing one of a plurality of instructions to said associative 
memory device; 

a clock device for outputting a synchronizing clock signal comprised of a 
predetermined number of clock cycles per second, said dock device outputting 
said synchronizing clock signal to said associative memory device and said 
controller; and 

wherein said controller globally communicates one of said plurality of 
instructions to all of said n-cells simultaneously, within one of said clock cycles. 

23. The data processing system of claim 22, further comprising: 

a classification device for selectively operating in association with a local 
state of each of said n-cells; and 

wherein one of said plurality of instructions is executed by selected cells 
within said associative memory device in dependence upon said local state of 
said n- cells as directed by said classification device, said execution of said 
instruction occurring simultaneously in each of said selected cells within one of 
said clock cycles. 

24. The data processing system of claim 23, wherein: 

each of said n-cells include a state field and a data field, said state field 
comprising a marker bit for encoding a local state of each of said n- cells, 
thereby indicating one of a marked state and a non-marked state of each of said 
n-cells. 

25. The data processing system of claim 24, wherein: 

one of said plurality of instructions issued by said controller is a 'load line 
immediate' command whereby the contents of all of said n- cells in said marked 
state are replaced with data indicated by said 'load line immediate' command. 
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26. The data processing system of claim 25, further comprising: 

a vector memory containing p- vectors, each of said p- vectors containing 
n-elements having m-bits each; and 

said data indicated by said load line immediate' command corresponds to 
5 one of said p- vectors. 

27. The data processing system of claim 24, further comprising: 

one of said plurality of instructions issued by said controller is a 'store line 
immediate' command whereby the contents of all of said n- cells in said marked 
state are saved to a memory vector indicated by said 'store line immediate' 
5 command. 

28. The data processing system of claim 24, wherein: 

one of said plurality of instructions issued by said controller is a 'left limit' 
command whereby a left limit of a search space is set to a leftmost cell of said n- 
cells in said marked state. 

29. The data processing system of claim 24, wherein: 

one of said plurality of instructions issued by said controller is a 'right 
limit' command whereby a right limit of a search space is set to a leftmost cell of 
said n- cells in said marked state. 

30. The data processing system of claim 24, wherein: 

said controller may dynamically limit a search space within said n- cells. 

31. The data processing system of claim 24, wherein: 

one of said plurality of instructions issued by said controller is a 'find' 
command whereby each of said n- cells holding values equal to an argument 
indicated by said 'find' command is identified; and 
5 wherein said 'find' command sets said marker bit to said marked state in 

each of said n- cells located to the right of said identified n- cells, and sets said 
marker bit to said non-marked state in all other of said n- cells. 
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32. The data processing system of claim 24^ wherein: 

one of said plurality of instructions issued by said controller is a 'match' 
conunand whereby each of said n- cells having a marker bit in said marked state 
and having said data field matching an argument indicated by said 'match* 
command, is identified; and 

wherein said 'match' command sets said marker bit to said marked state 
in each of said w- cells following said identified n- cells, and sets said marker bit 
to said non-marked state in all other of said n- cells. 

33. The data processing system of claim 24, wherein: 

one of said plurality of instructions issued by said controller is a 'find and 
mark left' command whereby each of said n- cells holding values equal to an 
argument indicated by said 'find and left mark* command is identified; and 

wherein said 'find* command sets said marker bit to said marked state in 
each of said n- cells located to the left of said identified n- cells, and sets said 
marker bit to said non-marked state in all other of said n- cells. 

34. The data processing system of claim 24, wherein: 

one of said plurality of instructions issued by said controller is a 'match 
and mark left' command whereby each of said n- cells having a marker bit in 
said marked state and having said data field matching an argument indicated by 
said 'match' command, is identified; and 

wherein said 'match* command sets said marker bit to said marked state 
in each of said n- cells located to the left of said identified n- cells. 

35. The data processing system of claim 28, wherein: 

one of said plurality of instructions issued by said controller is a 'markall' 
command whereby said marker bit of each of said n- cells within said search 
space is set to said marked state. 
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36. The data processing system of claim 24, wherein: 

one of said plurality of instructions issued by said controller is an 
'addmark' command whereby said marker bit of each of said «- cells containing 
a value equal to an argument indicated by said 'addmark* command is set to 
5 said marked state; and 

said 'addmark* command does not affect said marker bit of any other of 
said n- cells. 

37. The data processing system of claim 24, wherein: 

one of said plurality of instructions issued by said controller is a 'mark' 
command whereby said marker bit of each of said n- cells containing a value 
equal to an argument indicated by said 'mark' command is set to said marked 
5 state; and 

said mark' command sets said marker bit to said non-marked state in 
each of said n- cells not containing a value equal to an argument indicated by 
said 'mark' command. 

38. The data processing system of claim 24, wherein: 

one of said plurality of instructions issued by said controller is a 'clr' 
command whereby said marker bit of each of said cells containing a value 
equal to an argument indicated by said 'clr' command is set to said non-marked 
5 state. 

39. The data processing system of claim 24, wherein: 

one of said plurality of instructions issued by said controller is a 'clear 
first' command whereby said leftmost of said n- cells having said marker bit set 
to said marked state is set to said non-marked state. 

40. The data processing system of claim 24, wherein: 

one of said plurality of instructions issued by said controller is a 'trace' 
command whereby said marker bit of all of said w- cells is duplicated leftward in 
said associative memory device. 
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41. The data processing system of daim 24, wherein: 

one of said plurality of instructions issued by said controller is a 'keepl' 
command whereby said marker bit of all of said n- cells except for a rightmost 
of said n- cells in said marked state is set to said non-marked state. 

42. The data processing system of claim 24, wherein: 

one of said plurality of instructions issued by said controller is a 'clrl' 
command whereby said marker bit of a rightmost of said n-cells in said marked 
state is set to said non-marked state. 

43. The data processing system of claim 24, wherein: 
one of said plurality of instructions issued by said controller is 

command whereby all of said marker bits for said n- cells are shifted 
one. 

44. The data processing system of claim 24, wherein: 
one of said plurality of instructions issued by said controller is a 'right' 

command whereby all of said marker bits for said n- cells are shifted rightward 
by one. 

45. The data processing system of claim 24, wherein: 

one of said plurality of instructions issued by said controller is a 'cright' 
command whereby all of said marker bits for said n- cells that are in said 
marked state are shifted rightward by one to a next-right cell unless said next- 
5 right cell contains a value equal to an argument indicated by said 'cright' 
command; and 

said 'cright' command replaces said data field of said next-right cell with a 
predetermined value when said next-right cell contains a value equal to an 
argument indicated by said 'cright* command. 



a left' 
leftward by 
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46. The data processing system of claim 24, wherein: 

one of said plurality of instructions issued by said controller is a 'cleft' 
command whereby all of said marker bits for said w- cells that are in said 
marked state are shifted leftward by one to a next-left cell unless said next-leftt 
5 cell contains a value equal to an argument indicated by said 'cleft' command; and 

said 'cleft' command replaces said data field of said next-left cell with a 
predetermined value when said next-left cell contains a value equal to an 
argimient indicated by said 'cleft* command. 

47. The data processing system of claim 24, wherein: 

one of said plurality of instructions issued by said controller is a 'nop' 
command whereby no operation is executed. 

48. The data processing system of claim 24, wherein: 

one of said plurality of instructions issued by said controller is a 'reset' 
command whereby said data fields of said n- cells are assigned a value indicated 
by said 'reset' command. 

49. The data processing system of claim 24, wherein: 

one of said plurality of instructions issued by said controller is a 'get' 
command whereby a value stored in a leftmost cell of said n- cells in said 
marked state is outputted from said associative memory device; and 
5 said marker bit of said leftmost cell in said marked state is shifted to the 

right by one cell. 

50. The data processing system of claim 24, wherein: 

one of said plurality of instructions issued by said controller is a 'back' 
command whereby a value stored in a leftmost marked cell is outputted from 
said associative memory device; and 
5 said marker bit of said leftmost marked cell is shifted to the left by one 

cell. 
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51. The data processing system of claim 24, wherein: 

one of said plurality of instructions issued by said controller is a 'set' 
command whereby a value indicated by said 'set' command is stored in a 
leftmost of said n- cells in said marked state. 

52. The data processing system of claim 24, wherein: 

one of said plurality of instructions issued by said controller is a 'setall' 
command whereby a value indicated by said 'setair commeind is stored in all of 
said n- cells in said marked state. 

53. The data processing system of claim 24, wherein: 

one of said plurality of instructions issued by said controller is an 'ins' 
command whereby a value indicated by said *ins' command is stored in one of 
said n- cells at an insertion point located prior to a leftmost of said n- cells in said 
marked state; and 

said 'ins* command rightwardly shifts a content of each of said n- cells 
located to the right of said insertion point by one. 

54. The data processing system of claim 24, wherein: 

one of said plurality of instructions issued by said controller is a 'del' 
command whereby a data field of a leftmost of said w- cells in said marked state 
is deleted; and 

said 'del' command leftwardly shifts a content of each of said n- cells 
located to the right of said leftmost marked cell by one. 

55. The data processing system of claim 24, wherein: 

one of said plurality of instructions issued by said controller is a 'cpr' 
command whereby contents of all of said n- cells in said marked state are 
rightwardly copied by one. 
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56. The data processing system of claim 24, wherein: 

one of said plurality of instructions issued by said controller is a 'cpl' 
command whereby contents of all of said n- cells in said marked state are 
leftwardly copied by one. 

57. The data processing system of claim 24, wherein: 

one of said plurality of instructions issued by said controller is a *ccpr' 
command whereby contents of all of said n- cells in said marked state are 
rightwardly copied by one, including copying of said marked state; and 

said 'ccpr* command does not copy said marked state of said n- cells 
whose said contents equals a value indicated by said 'ccpr' command. 

58. The data processing system of claim 24, wherein: 

one of said plurality of instructions issued by said controller is a 'ccpl' 
command whereby contents of all of said cells in said marked state are 
leftwardly copied by one, including copying of said marked state; and 

said 'ccpr* command does not copy said marked state of said n- cells 
whose said contents equals a value indicated by said 'ccpl* command. 

59. The data processing system of daim 24, wherein: 

one of said plurality of instructions issued by said controller is a Id' 
command whereby a value indicated by said Id' command is loaded into said 
data field in all of said n- cells in said marked state. 

60. The data processing system of claim 24, further comprising: 
a vector memory containing p- vectors; and 

one of said plurality of instructions issued by said controller is a 'st' 
command whereby contents of said data field in all of said n- cells in said 
marked state are copied to a corresponding location in one of said p- vectors as 
indicated by said *st' command. 
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61. The data processing system of claim 24, wherein: 

one of said plurality of instructions issued by said controller is an 'add' 
command whereby a value indicated by said 'add* command is added to said 
data field in all of said n- cells in said marked state. 

62. The data processing system of claim 24, wherein: 

one of said plurality of instructions issued by said controller is a *fadd' 
command whereby a value indicated by said 'fadd* conwnand is added to said 
data field in all of said cells in said marked state; and 

wherein a leftmost bit of said data field of a ceU within said associative 
memory device positioned to the right of each of said n- cells in said marked 
state acts as a carry bit. 

63. The data processing system of claim 24, wherein: 

one of said plurality of instructions issued by said controller is a 'sub' 
command whereby a value indicated by said 'sub' command is subtracted from 
said data field in all of said n- cells in said marked state. 

64. The data processing system of claim 24, wherein: 

one of said plurality of instructions issued by said controller is a 'fsub' 
command whereby a value indicated by said 'fsub' command is subtracted from 
said data field in all of said n- cells in said marked state; and 

wherein a leftmost bit of said data field of a cell within said associative 
memory device positioned to the right of each of said n- cells in said marked 
state acts as a carry bit. 

65. The data processing system of claim 24, wherein: 

one of said plurality of instructions issued by said controller is a 'half 
command whereby said data field in all of said n- cells in said marked state is 
divided by two. 
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66. The data processing system of claim 24, wherein: 

one of said plurality of instructions issued by said controller is an 'fhalf ' 
command whereby said data field in all of said n- cells in said marked state is 
divided by two; and 

wherein 1 is added to a leftmost bit of said data field if a least significant 
data bit of a cell within said associative memory device positioned to the left of 
each of said n- cells is in said marked state. 

67. The data processing system of claim 24, wherein: 

one of said plurality of instructions issued by said controller is a *lt' 
command whereby a value indicated by said 'It' command is compared to said 
data field in all of said n- cells in said marked state; 

said 'It* command sets said marker bit of said n- cells in said marked state 
to said non-marked state if said value indicated by said 'it' command is greater 
than said data field; and 

said It' command sets to 1 a leftmost bit of said data field of said n- cells in 
said marked state if said value indicated by said 'It' command is less than said 
data field. 

68. The data processing system of claim 24, wherein: 

one of said plurality of instructions issued by said controller is a 'fit' 
command whereby a value indicated by said 'fit' command is compared to said 
data field in all of said n- cells in said marked state; 

said 'fit' command sets said marker bit of said n- cells in said marked state 
to said non-marked state if said value indicated by said 'fit' command is greater 
than said data field and a leftmost bit of said data field of a cell within said 
associative memory device positioned to the left of each of said n- cells in said 
marked state is zero; 

said 'fit' command sets to 1 a leftmost bit of said data field of said n- cells 
in said marked state if said value indicated by said 'fit' command is less than said 
data field; 
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said 'fit' command sets to 1 a leftmost bit of said data field of said w- cells 
in said marked state if said leftmost bit of a cell within said associative memory 
1 5 device positioned to the left of each of said n- cells in said marked state is 1; and 
said 'fit' command sets to 0 said leftmost bit of a cell within said 
associative memory device positioned to the left of each of said n- cells in said 
marked state. 

69. The data processing system of claim 24, wherein: 

one of said plxirality of instructions issued by said controller is a 'gt' 
command whereby a value indicated by said 'gt' command is compared to said 
data field in all of said n- cells in said marked state; 
5 said 'gt' command sets said marker bit of said n- cells in said marked state 

to said non-marked state if said value indicated by said 'gt' command is less than 
said data field; and 

said 'gt' command sets to 1 a leftmost bit of said data field of said n- cells 
in said marked state if said value indicated by said 'gt' command is greater than 
1 0 said data field. 

70. The data processing system of claim 24, wherein: 

one of said plurality of instructions issued by said controller is a 'fgt' 
command whereby a value indicated by said 'fgt' command is compared to said 
data field in all of said n- cells in said marked state; 
5 said 'fgt' command sets said marker bit of said n- cells in said marked 

state to said non-marked state if said value indicated by said 'fgt' command is 
less than said data field and a leftmost bit of said data field of a cell within said 
associative memory device positioned to the left of each of said n- cells in said 
marked state is zero; 

1 0 said 'fgt' command sets to 1 a leftmost bit of said data field of said n- cells 

in said marked state if said value indicated by said 'fgt' conrunand is greater than 
said data field; 

said 'fgt' command sets to 1 a leftmost bit of said data field of said n- cells 
in said marked state if said leftmost bit of a cell within said associative memory 
1 5 device positioned to the left of each of said n- cells in said marked state is 1; and 
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said 7gt' command sets to 0 said leftmost bit of a cell within said 
associative memory device positioned to the left of each of said n- cells in said 
marked state. 



71. The data processing system of claim 24, wherein: 

one of said plurality of instructions issued by said controller is a 'test' 
command whereby for all of said n- cells in said marked state that contain a 
value indicated by said 'test' command, said 'test' command sets said marker bit 
5 to said non-marked state; and 

said 'test' command assigns a predetermined value to said data field of all 
of said n- cells having said indicated value if a leftmost bit of a cell to the left of 
all of said n- cells having said indicated value is 1; and 

said 'test' command clears a leftmost bit of said cell to the left of all of said 
10 n- cells having said indicated value, if said leftmost bit is 1. 

72. The data processing system of claim 24, wherein: 

one of said plurality of instructions issued by said controller is an 'and' 
command whereby for all of said n- cells in said marked state, said 'and' 
command accomplishes a bitwise AND of a value indicated by said 'and' 
5 command and said data field in all of said n- cells in said marked state. 



73. The data processing system of claim 24, wherein: 

one of said plurality of instructions issued by said controller is an 'or' 
command whereby for all of said n- cells in said marked state, said 'or' 
command accomplishes a bitwise OR of a value indicated by said 'or' command 
5 and said data field in all of said n- cells in said marked state. 



74. The data processing system of claim 24, wherein: 

one of said plurality of instructions issued by said controller is a 'xor' 
command whereby for all of said n- cells in said marked state, said xor' 
command accomplishes a bitwise XOR of a value indicated by said 'xor' 
5 command and said data field in all of said n- cells in said marked state. 
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75. The data processing system of claim 24, wherein: 

one of said plurality of instructions issued by said controller is a *cond' 
command whereby for all of said n- cells in said marked state, said 'cond* 
command switches their marked state to said non-marked state if a result of a 
5 bitwise AND operation between a value indicated by said 'cond' command and 
said data field of all of said n- cells in said marked state is 0. 

76. The data processing system of claim 24, wherein: 

one of said plurality of instructions issued by said controller is a 'ncond' 
command whereby for all of said «- cells in said marked state, said 'ncond* 
command switches their marked state to said non-marked state if a result of a 
5 bitwise AND operation between a value indicated by said 'ncond' command and 
said data field of all of said n- cells in said marked state is not 0. 

77. The data processing system of claim 71, wherein: 

one of said plurality of instructions issued by said controller is an 'index' 
command whereby for all of said n- cells in said marked state, said 'index' 
command assigns a value to each of said marked n- cells indicative of each of 
5 said marked n- cells position relative to a leftmost of said n- cells. 

78. The data processing system of claim 22, wherein: 

said classification device determines a global state of each of said n-cells; 

and 

wherein said one of said plurality of instructions is executed by selected 
5 cells within said associative memory device in dependence upon both said local 
state and said global state of said n- cells, said execution of said instruction 
occurring simultaneously in each of said selected cells within one of said clock 
cycles. 

79. The data processing system of claim 22, wherein: 

said associative memory device allows the use of variable-length key 

fields. 
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80. The data processing system of claim 78, wherein: 

said variable-length key fields include a data field and a key field, each of 
said n- cells having said data field and said key field; and 

wherein data stored in each of said n- cells is alternatively considered as 
part of said data field and said key field at different times during execution of 
one of said plurality of instructions. 

81. A method of processing data, said method comprising the steps of: 
forming an associative memory device to contain «-cells; 
configuring each of said n-cells to include a processing circuit; 
issuing one of a plurality of instructions from a controller to said 

associative memory device; 

utilizing a clock device for outputting a synchronizing clock signal 
comprised of a predetermined nimiber of clock cycles per second, said clock 
device outputting said synchronizing clock signal to said associative memory 
device and said controller; and 

globally communicating one of said plurality of instructions from said 
controller to all of said n-cells simultaneously, within one of said clock cycles. 

82. A data processing system, said data processing system comprising: 
a memory device containing n-cells, each of said n-cells including a 

processing circuit; 

a controller for issuing one of a plurality of instructions to said associative 
memory device; 

a clock device for outputting a synchronizing clock signal comprised of a 
predetermined number of clock cycles per second, said clock device outputting 
said synchronizing clock signal to said associative memory device and said 
controller; and 

wherein said controller globally communicates one of said plurality of 
instructions to all of said w<ells simultaneously, within one of said clock cycles. 
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